#meta

Allows for quick definition of slash commands based on templates.

Creating slash templates

Create a page with the #meta/template/slash tag. The last component of the page name (after the / if any) will be used as the slash command’s name. The body of the page will be used as the text to be inserted, using Lua directives is supported.

Configuration

You can configure some specifics about your slash template in its template page’s frontmatter.

Optional keys:
  • description: The description of the slash command
  • boost: To prioritize the slash command higher in the list
  • onlyContexts (advanced): To only make the slash command appear in certain (AST node based) contexts
  • exceptContexts (advanced): To make the slash command appear everywhere except in these (AST node) contexts


Examples



Implementation

for st in query[[
    from index.tag "meta/template/slash"
    where _.tag == "page"
  ]] do
  local components = st.name:split("/")
  local name = components[#components]
  slashcommand.define {
    name = name,
    description = st.description,
    boost = st.boost,
    onlyContexts = st.onlyContexts,
    exceptContexts = st.exceptContexts,
    run = function()
      local tpl = template.fromPage(st.name, st.raw)
      editor.insertAtCursor(tpl(), false, true)
    end
  }
end